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codes can be executed on each of the different systems, therefore downloading or compihng 
multiple copies of code can be avoided. The code can be compiled once and downloaded as 
needed to the various servers as byte-codes and then exe cuted.-- 

IN THE CLAIMS: 



Please cancel c^ms 1 and 2, substitute clean amended claims 3, 9, 11-12, 17 and 18 for 
the pending claims with the same number, and add claims 28-52 as follows: 

3. (Amended) A method performed on a processor operatively coupled to a 
collection of servers which enables a cHent associated with the processor to dynamically 
distribute a task to a server, the method comprising the steps of: 

selecting a server to process the task; 

forming a task request from parameters and data; 

sending the task request to the selected server which downloads any needed executable 
byte code, invokes a generic compute technique capable of executing the task request on the 
selected server and generates results; and 

receiving the results back from the selected server. 

9. (Amended) The method of claim 3, wherein selecting the server comprises 
selecting the server based on the overall processing load distribution among the collection of 
servers. 

1 1 . (Amended) The method of claim 3, wherein selecting the server comprises 
selecting the server based on the specialized computing capabilities of each server. 
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12. (Amended) The method of claim 11, wherein the speciaUzed computing 
capabiUties include a capability to render images. 






17. (Amended) The method of claim 3, wherein the results comprise an object. 

1 8. (Amended) A method performed on a processor operatively coupled to a 
collection of servers which enables a server associated with the processor to dynamically receive 
and process a task from a client computer wherein the task is in an executable programming 
language compatible with each of the server computers, the method comprising the steps of: 

retrieving parameters and data from a task request into a task; 
downloading any needed executable byte code; 

invoking a generic compute method on the server, which is capable of processing a 
plurality of types of tasks, which executes the task and generates results; and 
returning results to the client. 
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—28. A computer readable medium containing instructions for controlling a computer 
system comprising a collection of servers to perform a method for enabling a client to 
dynamically distribute a task to a server, the method comprising the steps of: 

selecting a server to process the task; 

forming a task request from parameters and data; 

sending the task request to the selected server which dovmloads any needed executable 
byte code, invokes a generic compute method capable of executing the task request on the 
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selected server and generates results; and 

receiving the results back from the selected server. 



29. The computer readable medium of claim 28, v^herein the computer system is 
operatively coupled to a primary storage device, a secondary storage device, a display device, 
and an input/output mechanism. 

30. The computer readable medium of claim 28, wherein the task is developed in a 
programming language and environment compatible with each of the servers. 



3 1 . The computer readable medium of claim 28, wherein the selected server is 
selected from a plurality of heterogeneous computer systems. 

32. The computer readable medium of claim 30, wherein the environment includes a 
remote procedure call subsystem. 

33. The computer readable medium of claim 32, wherein the remote procedure call 
subsystem is the Remote Method hivocation (RMI) system. 
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34. The computer readable medium of claim 28, wherein selecting the server 
comprises selecting the server based on the overall processing load distribution among the 
collection of servers. 
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35. The computer readable medium of claim 28, wherein selecting the server 
comprises selecting the server based on a lowest load characteristic compared to an average load 
characteristic of the servers over a predetermined period of time. 
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36. The computer readable medium of claim 28, wherein selecting the server 
comprises selecting the server based on the specialized computing capabilities of each server. 

37. The computer readable medium of claim 36, wherein the specialized computing 
capabilities include a capability to render images. 
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38. The computer readable medium of claim 28, wherein the sending step further 
comprises: 

determining whether code related to the requested task is present on the selected server; 

and 

downloading the code onto the selected server if the code is not present on the selected 

server. 

39. The computer readable medium of claim 28, wherein the sending step further 
comprises: 

providing the task as a parameter to the generic compute method. 
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40. The computer readable medium of claim 28 further comprising the step of 
indicating to the server that results from a computed task should be stored in a result cache on the 
selected server for subsequent tasks to use. 

41 . The computer readable medium of claim 28, wherein the results are used for 
further processing on the client. 

42. The computer readable medium of claim 28, v^herein the results comprise an 

object. 

43. A computer readable medium containing instructions for controlling a computer 
system comprising a collection of servers to perform a method for enabling a server to 
dynamically receive and process a task from a client computer v^herein the task is in an 
executable programming language compatible with each of the servers, the method comprising 
the steps of: 

retrieving parameters and data from a task request into a task; 
downloading any needed executable byte code; 

invoking a generic compute method on the server, which is capable of processing a 
plurality of types of tasks, which executes the task and generates results; and 
returning results to the client. 
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44. The computer readable medium of claim 43, wherein the computer system is 
operatively coupled to a primary storage device, a secondary storage device, a display device, 
and an input/output mechanism. 
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45. The computer readable medium of claim 43, wherein the task is developed in a 
programming language compatible with each of the servers. 

46. The computer readable medium of claim 43, wherein the task is developed using a 
Java programming language and environment. 

47. The computer readable medium of claim 43, wherein the environment includes a 
remote procedure call subsystem. 

48. The computer readable medium of claim 47, wherein the remote procedure call 
subsystem is the Remote Method Invocation (RMI) system. 

49. The computer readable medium of claim 43, wherein the retrieving step further 
comprises: 

determining if types related to the task are available on the server; 
when the types are not available on the server, dovraloading the types onto the server 
from a location as indicated by the parameters provided by the client; and 

executing the task based upon the data and parameters provided by the client. 
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